## ECE 3561 MT Register Set

12/03/19

Matt Gambill

```
regLine Code Listing
```

```
LIBRARY IEEE;
USE IEEE.STD_LOGIC_1164.ALL;
ENTITY regLine IS
     PORT (
           ABUS, BBUS
                                                       : INOUT
std logic vector(15 DOWNTO 0);
           Aload, Bload, Adrive, Bdrive, Arsel, Brsel : IN std logic
     );
END regLine;
ARCHITECTURE one OF regLine IS
      -- define subcomponents
     COMPONENT busdr IS
           PORT (
                    : IN std logic;
                datain : IN std_logic_vector(15 DOWNTO 0);
                dataout : OUT std logic vector(15 DOWNTO 0)
           );
      END COMPONENT;
      FOR ALL: busdr USE ENTITY work.busdr(one);
      COMPONENT reg16 IS
           PORT (
                  din : IN std logic vector(15 DOWNTO 0);
                 dout : OUT std logic vector(15 DOWNTO 0);
                  load : IN std logic
```

```
);
      END COMPONENT;
      FOR ALL: reg16 USE ENTITY WORK.reg16(one);
      COMPONENT mux2 to 1x16 IS
            PORT (
                  a, b : IN std logic vector(15 DOWNTO 0);
                  sa, sb : IN std logic;
                 muxout : OUT std logic vector(15 DOWNTO 0)
            );
      END COMPONENT;
      SIGNAL mux0 out, regOut : std logic vector(15 DOWNTO 0);
      SIGNAL regLoad, Abusdr load, Bbusdr load : std logic;
      BEGIN
            mux0 : mux2 to 1x16
            PORT MAP(ABUS, BBUS, Arsel, Brsel, mux0_out);
            reg0 : reg16
                            PORT MAP(mux0 out, regOut, regLoad);
            Abusdr : busdr PORT MAP(Abusdr_load, regOut, ABUS);
            Bbusdr : busdr PORT MAP(Bbusdr load, regOut, BBUS);
            Abusdr_load <= (Adrive) AND (Arsel);
            Bbusdr_load <= (Bdrive) AND (Brsel);</pre>
            regLoad <= (Aload AND Arsel) OR (Bload AND Brsel);</pre>
END one;
```

| <b>♦</b>        | Msgs                                    |  |                |    |          |          |  |          |          |  |          |          |  |          |          |  |          |          |
|-----------------|-----------------------------------------|--|----------------|----|----------|----------|--|----------|----------|--|----------|----------|--|----------|----------|--|----------|----------|
|                 | ZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZ |  | 00001111000011 | 11 | 00001111 | 00001111 |  |          |          |  |          |          |  |          |          |  | 11110000 | 11110000 |
| + /tregin/BBUS  | ZZZZZZZZZZZZZZZZZZZ                     |  |                |    |          |          |  | 00001111 | 00001111 |  | 11110000 | 11110000 |  | 11110000 | 11110000 |  |          |          |
| /tregln/Aload   | 0                                       |  |                |    |          |          |  |          |          |  |          |          |  |          |          |  |          |          |
| 🔷 /tregln/Bload | 0                                       |  |                |    |          |          |  |          |          |  |          |          |  |          |          |  |          |          |
| /tregln/Adrive  | 0                                       |  |                |    |          |          |  |          |          |  |          |          |  |          |          |  |          |          |
| /tregln/Bdrive  | 0                                       |  |                |    |          |          |  |          |          |  |          |          |  |          |          |  |          |          |
| /tregln/Arsel   | 0                                       |  |                |    |          |          |  |          |          |  |          |          |  |          |          |  |          |          |
| /tregln/Brsel   | 0                                       |  |                |    |          |          |  |          |          |  |          |          |  |          |          |  |          |          |
|                 |                                         |  |                |    |          |          |  |          |          |  |          |          |  |          |          |  |          |          |

Flow Status Successful - Tue Dec 03 17:13:23 2019 Quartus Prime Version 18.1.0 Build 625 09/12/2018 SJ Lite Edition Revision Name MT1Q Top-level Entity Name regLine Family Cyclone V Device 5CSEMA5F31C6 Timing Models Final Logic utilization (in ALMs) 10 / 32,070 ( < 1 % ) Total registers 16 Total pins 38 / 457 (8%) Total virtual pins 0 Total block memory bits 0 / 4,065,280 ( 0 % ) Total DSP Blocks 0/87(0%) Total HSSI RX PCSs Total HSSI PMA RX Deserializers 0 Total HSSI TX PCSs Total HSSI PMA TX Serializers 0 Total PLLs 0/6(0%) Total DLLs 0/4(0%)



## regSet Code Listing

```
LIBRARY IEEE;
USE IEEE.STD_LOGIC_1164.ALL;
ENTITY regSet IS
      PORT (
            ABUS, BBUS
                                          : INOUT std logic vector(15 DOWNTO
0);
            Aload, Bload, Adrive, Bdrive : IN std logic;
                                          : IN std logic vector(2 downto 0)
            Aregno, Bregno
      );
END regSet;
ARCHITECTURE one OF regSet IS
      -- define subcomponents
      COMPONENT regLine IS
      PORT (
            ABUS, BBUS
                                                         : INOUT
std logic vector(15 DOWNTO 0);
            Aload, Bload, Adrive, Bdrive, Arsel, Brsel : IN std logic
      );
      END COMPONENT;
      COMPONENT pri3to8 IS
            PORT (pri : IN std_logic_vector(2 downto 0);
            p0,p1,p2,p3,p4,p5,p6,p7 : OUT std logic);
      END COMPONENT;
      SIGNAL Arsel0, Arsel1, Arsel2, Arsel3, Arsel4, Arsel5, Arsel6, Arsel7:
std logic;
```

```
SIGNAL Brsel0, Brsel1, Brsel2, Brsel3, Brsel4, Brsel5, Brsel6, Brsel7 : std logic;
```

## BEGIN regLine0 : regLine PORT MAP(ABUS, BBUS, Aload, Bload, Adrive, Bdrive, Arsel0, Brsel0); regLine1 : regLine PORT MAP(ABUS, BBUS, Aload, Bload, Adrive, Bdrive, Arsell, Brsel1); regLine2 : regLine PORT MAP(ABUS, BBUS, Aload, Bload, Adrive, Bdrive, Arsel2, Brsel2); regLine3 : regLine PORT MAP (ABUS, BBUS, Aload, Bload, Adrive, Bdrive, Arsel3, Brsel3); regLine4: regLine PORT MAP(ABUS, BBUS, Aload, Bload, Adrive, Bdrive, Arsel4, Brsel4); regLine5 : regLine PORT MAP (ABUS, BBUS, Aload, Bload, Adrive, Bdrive, Arsel5, Brsel5); regLine6 : regLine PORT MAP (ABUS, BBUS, Aload, Bload, Adrive, Bdrive, Arsel6, Brsel6); regLine7 : regLine PORT MAP (ABUS, BBUS, Aload, Bload, Adrive, Bdrive, Arsel7, Brsel7);

```
Aencoder : pri3to8 PORT
MAP(Aregno, Arsel0, Arsel1, Arsel2, Arsel3, Arsel4, Arsel5, Arsel6, Arsel7);
Bencoder : pri3to8 PORT
MAP(Bregno, Brsel0, Brsel1, Brsel2, Brsel3, Brsel4, Brsel5, Brsel6, Brsel7);
```

END one;

Flow Status Successful - Tue Dec 03 17:54:34 2019

Quartus Prime Version 18.1.0 Build 625 09/12/2018 SJ Lite Edition

Revision Name MT1Q
Top-level Entity Name regSet
Family Cyclone V

Device 5CSEMA5F31C6

Timing Models Final

Logic utilization (in ALMs) 174 / 32,070 ( < 1 % )

Total registers 128

Total pins 42 / 457 ( 9 % )

Total virtual pins 0

Total block memory bits 0 / 4,065,280 ( 0 % )

Total DSP Blocks 0 / 87 (0%)

Total HSSI RX PCSs 0

Total HSSI PMA RX Deserializers 0

Total HSSI TX PCSs 0

Total HSSI PMA TX Serializers 0

Total PLLs 0 / 6 (0 %)
Total DLLs 0 / 4 (0 %)

